//给你一个整数数组 arr 和两个整数 k 和 threshold 。 
//
// 请你返回长度为 k 且平均值大于等于 threshold 的子数组数目。 
//
// 
//
// 示例 1： 
//
// 
//输入：arr = [2,2,2,2,5,5,5,8], k = 3, threshold = 4
//输出：3
//解释：子数组 [2,5,5],[5,5,5] 和 [5,5,8] 的平均值分别为 4，5 和 6 。其他长度为 3 的子数组的平均值都小于 4 （
//threshold 的值)。
// 
//
// 示例 2： 
//
// 
//输入：arr = [11,13,17,23,29,31,7,5,2,3], k = 3, threshold = 5
//输出：6
//解释：前 6 个长度为 3 的子数组平均值都大于 5 。注意平均值不是整数。
// 
//
// 
//
// 提示： 
//
// 
// 1 <= arr.length <= 10⁵ 
// 1 <= arr[i] <= 10⁴ 
// 1 <= k <= arr.length 
// 0 <= threshold <= 10⁴ 
// 
//
// Related Topics 数组 滑动窗口 👍 73 👎 0

package leetcode.editor.cn;
//java:大小为 K 且平均值大于等于阈值的子数组数目
public class Q1343NumberOfSubArraysOfSizeKAndAverageGreaterThanOrEqualToThreshold {
    public static void main(String[] args){
        Solution solution = new Q1343NumberOfSubArraysOfSizeKAndAverageGreaterThanOrEqualToThreshold().new Solution();
    }
    //leetcode submit region begin(Prohibit modification and deletion)
class Solution {
    public int numOfSubarrays(int[] arr, int k, int threshold) {
        if (arr == null || arr.length == 0 || arr.length > 100000) {
            return 0;
        }
        // 初始化，计算初始结果
        int count = 0, sum = 0;
        for (int i = 0; i < k; i++) {
            sum += arr[i];
        }
        if (sum / k >= threshold) {
            count++;
        }
        for (int i = k; i < arr.length; i++) {
            sum -= arr[i - k];
            sum += arr[i];
            if (sum / k >= threshold) {
                count++;
            }
        }
        return count;
    }
}
//leetcode submit region end(Prohibit modification and deletion)

}